return mfn_to_virt(xen_start_info->console_mfn);
}
-static inline void notify_daemon(void)
-{
- /* Use evtchn: this is called early, before irq is set up. */
- notify_remote_via_evtchn(xen_start_info->console_evtchn);
-}
-
int xencons_ring_send(const char *data, unsigned len)
{
int sent = 0;
wmb();
intf->out_prod = prod;
- notify_daemon();
+ /* Use evtchn: this is called early, before irq is set up. */
+ notify_remote_via_evtchn(xen_start_info->console_evtchn);
return sent;
}
1, regs);
}
- mb();
+ wmb();
intf->in_cons = cons;
- notify_daemon();
-
return IRQ_HANDLED;
}
xencons_irq = err;
- /* In case we have in-flight data after save/restore... */
- notify_daemon();
-
return 0;
}
#include <asm-xen/xenbus.h>
#include "xenbus_comms.h"
-static int xenbus_irq;
+static int xenbus_irq = 0;
extern void xenbus_probe(void *);
extern int xenstored_ready;
static irqreturn_t wake_waiting(int irq, void *unused, struct pt_regs *regs)
{
- if (unlikely(xenstored_ready == 0)) {
+ if(unlikely(xenstored_ready == 0)) {
xenstored_ready = 1;
schedule_work(&probe_work);
}
xenbus_irq = err;
+ /* FIXME zero out page -- domain builder should probably do this*/
+ memset(mfn_to_virt(xen_start_info->store_mfn), 0, PAGE_SIZE);
+
return 0;
}
*store_mfn = page_array[(vstoreinfo_start-dsi.v_start) >> PAGE_SHIFT];
*console_mfn = page_array[(vconsole_start-dsi.v_start) >> PAGE_SHIFT];
- if ( xc_clear_domain_page(xc_handle, dom, *store_mfn) ||
- xc_clear_domain_page(xc_handle, dom, *console_mfn) )
- goto error_out;
+
start_info = xc_map_foreign_range(
xc_handle, dom, PAGE_SIZE, PROT_READ|PROT_WRITE,
#include "xg_private.h"
#include "xg_save_restore.h"
+
+
/* max mfn of the whole machine */
static uint32_t max_mfn;
return 0;
}
-int xc_clear_domain_page(int xc_handle,
- uint32_t domid,
- unsigned long dst_pfn)
-{
- void *vaddr = xc_map_foreign_range(
- xc_handle, domid, PAGE_SIZE, PROT_WRITE, dst_pfn);
- if ( vaddr == NULL )
- return -1;
- memset(vaddr, 0, PAGE_SIZE);
- munmap(vaddr, PAGE_SIZE);
- return 0;
-}
-
unsigned long xc_get_filesz(int fd)
{
uint16_t sig;
}
*store_mfn = page_array[(v_end-2) >> PAGE_SHIFT];
- if ( xc_clear_domain_page(xc_handle, dom, *store_mfn) )
- goto error_out;
-
shared_page_frame = (v_end - PAGE_SIZE) >> PAGE_SHIFT;
if ((e820_page = xc_map_foreign_range(
int xc_copy_to_domain_page(int xc_handle, uint32_t domid,
unsigned long dst_pfn, void *src_page);
-int xc_clear_domain_page(int xc_handle, uint32_t domid,
- unsigned long dst_pfn);
-
int xc_ia64_copy_to_domain_pages(int xc_handle, uint32_t domid,
void* src_page, unsigned long dst_pfn, int nr_pages);